<template><div><h2 id="配置信息" tabindex="-1"><a class="header-anchor" href="#配置信息"><span>配置信息</span></a></h2>
<ul>
<li><a href="#introduction">介绍</a></li>
<li><a href="#environment-configuration">环境配置</a>
<ul>
<li><a href="#environment-variable-types">环境变量类型</a></li>
<li><a href="#retrieving-environment-configuration">检索环境配置</a></li>
<li><a href="#determining-the-current-environment">确定当前环境</a></li>
<li><a href="#encrypting-environment-files">环境文件加密</a></li>
</ul>
</li>
<li><a href="#accessing-configuration-values">访问配置值</a></li>
<li><a href="#configuration-caching">缓存配置</a></li>
<li><a href="#debug-mode">调试模式</a></li>
<li><a href="#maintenance-mode">维护模式</a></li>
</ul>
<h2 id="介绍" tabindex="-1"><a class="header-anchor" href="#介绍"><span>介绍</span></a></h2>
<p>Laravel 框架的所有配置文件都存储在<code v-pre>config</code>目录中。每个选项都有文档记录，因此请随意查看文件并熟悉可用的选项。</p>
<p>这些配置文件允许你配置诸如数据库连接信息、邮件服务器信息以及各种其他核心配置值（例如应用程序时区和加密密钥）之类的事项。</p>
<h4 id="应用概述" tabindex="-1"><a class="header-anchor" href="#应用概述"><span>应用概述</span></a></h4>
<p>为了方便你可以通过<code v-pre>about</code>Artisan 命令快速了解应用程序的配置、驱动程序和环境：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan about</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>如果只对应用程序概述输出的特定部分感兴趣，则可以使用<code v-pre>--only</code>选项过滤该部分：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan about <span class="token parameter variable">--only</span><span class="token operator">=</span>environment</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>或者，如果你想详细了解特定配置文件的值，你可以使用<code v-pre>config:show</code> Artisan命令：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan config:show database</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h2 id="环境配置" tabindex="-1"><a class="header-anchor" href="#环境配置"><span>环境配置</span></a></h2>
<p>根据应用程序运行的环境，有不同的配置值通常是有帮助的。例如，你可能希望在本地使用不同的缓存驱动程序，而在生产服务器上则使用另一个。</p>
<p>为了使这个过程变得简单，Laravel 利用了 <a href="https://github.com/vlucas/phpdotenv" target="_blank" rel="noopener noreferrer">DotEnv</a> PHP 库。在新安装的 Laravel 应用程序中，你的应用程序的根目录将包含一个定义许多常见环境变量的<code v-pre>.env.example</code>文件。在 Laravel 安装过程中，这个文件将自动被复制到<code v-pre>.env</code>。</p>
<p>Laravel 的默认<code v-pre>.env</code>文件包含一些常见的配置值，这些值可能会根据你的应用程序是在本地运行还是在生产Web服务器上运行而有所不同。然后，这些值将使用 Laravel 的<code v-pre>env</code>函数从<code v-pre>config</code>目录中的各种 Laravel 配置文件中检索出来。</p>
<p>如果你正在与团队一起开发，你可能希望继续在你的应用程序中包含一个<code v-pre>.env.example</code>文件。通过在示例配置文件中放置占位符值，你的团队中的其他开发人员可以清楚地看到运行你的应用程序需要哪些环境变量。</p>
<blockquote>
<p><strong>技巧</strong><br>
<code v-pre>.env</code>文件中的任何变量都可以被外部环境变量覆盖，例如服务器级或系统级环境变量。</p>
</blockquote>
<h4 id="环境文件安全" tabindex="-1"><a class="header-anchor" href="#环境文件安全"><span>环境文件安全</span></a></h4>
<p>你的<code v-pre>.env</code>文件不应该提交到版本管理器中，首先，使用应用程序的每个开发人员 / 服务器可能需要不同的环境配置。其次，如果入侵者获得了对版本管理器的访问权限，这将成为一个安全风险，他将能看到配置文件中的敏感数据。</p>
<p>但是，可以使用 Laravel 的内置 <a href="#encrypting-environment-files">加密环境</a>。加密环境文件可以安全地放置在源代码管理中。</p>
<h4 id="附加环境文件" tabindex="-1"><a class="header-anchor" href="#附加环境文件"><span>附加环境文件</span></a></h4>
<p>在加载应用程序的环境变量之前，Laravel 会确定是否已经从外部提供了<code v-pre>APP_ENV</code>环境变量，或者是否指定了<code v-pre>--env</code>CLI 参数。如果是这样，Laravel 将尝试加载一个<code v-pre>.env.[APP_ENV]</code>文件（如果它存在）。 如果它不存在，将加载默认的<code v-pre>.env</code>文件。</p>
<h3 id="环境变量类型" tabindex="-1"><a class="header-anchor" href="#环境变量类型"><span>环境变量类型</span></a></h3>
<p><code v-pre>.env</code>文件中的所有变量通常都被解析为字符串，因此创建了一些保留值以允许你从<code v-pre>env()</code>函数返回更广泛的类型：</p>
<table>
<thead>
<tr>
<th><code v-pre>.env</code> Value</th>
<th><code v-pre>env()</code> Value</th>
</tr>
</thead>
<tbody>
<tr>
<td>true</td>
<td>(bool) true</td>
</tr>
<tr>
<td>(true)</td>
<td>(bool) true</td>
</tr>
<tr>
<td>false</td>
<td>(bool) false</td>
</tr>
<tr>
<td>(false)</td>
<td>(bool) false</td>
</tr>
<tr>
<td>empty</td>
<td>(string) ‘’</td>
</tr>
<tr>
<td>(empty)</td>
<td>(string) ‘’</td>
</tr>
<tr>
<td>null</td>
<td>(null) null</td>
</tr>
<tr>
<td>(null)</td>
<td>(null) null</td>
</tr>
</tbody>
</table>
<p>如果你需要使用包含空格的值定义环境变量，可以通过将值括在双引号中来实现：</p>
<div class="language-ini line-numbers-mode" data-highlighter="prismjs" data-ext="ini" data-title="ini"><pre v-pre class="language-ini"><code><span class="line"><span class="token key attr-name">APP_NAME</span><span class="token punctuation">=</span><span class="token value attr-value">"<span class="token inner-value">My Application</span>"</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h3 id="获取环境配置" tabindex="-1"><a class="header-anchor" href="#获取环境配置"><span>获取环境配置</span></a></h3>
<p>当应用程序收到请求时<code v-pre>.env</code>文件中列出的所有变量将被加载到 PHP 的超级全局变量<code v-pre>$_ENV</code>中。你可以使用<code v-pre>env</code>函数检索这些变量的值。实际上，如果你看过 Laravel 的配置文件，就能注意到有数个选项已经使用了这个函数：</p>
<div class="language-php line-numbers-mode" data-highlighter="prismjs" data-ext="php" data-title="php"><pre v-pre class="language-php"><code><span class="line"><span class="token string single-quoted-string">'debug'</span> <span class="token operator">=></span> <span class="token function">env</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'APP_DEBUG'</span><span class="token punctuation">,</span> <span class="token constant boolean">false</span><span class="token punctuation">)</span><span class="token punctuation">,</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p><code v-pre>env</code>函数的第二个参数是「默认值」。 当没有找到对应环境变量时将返回 「默认值」。</p>
<h3 id="获取当前环境配置" tabindex="-1"><a class="header-anchor" href="#获取当前环境配置"><span>获取当前环境配置</span></a></h3>
<p>当前应用的环境配置是从你的<code v-pre>.env</code>文件中的<code v-pre>APP_ENV</code>变量配置的。你可以通过<code v-pre>App</code> <a href="https://learnku.com/docs/laravel/10.x/facades" target="_blank" rel="noopener noreferrer">facade</a> 的<code v-pre>environment</code>函数获取：</p>
<div class="language-php line-numbers-mode" data-highlighter="prismjs" data-ext="php" data-title="php"><pre v-pre class="language-php"><code><span class="line"><span class="token keyword">use</span> <span class="token package">Illuminate<span class="token punctuation">\</span>Support<span class="token punctuation">\</span>Facades<span class="token punctuation">\</span>App</span><span class="token punctuation">;</span></span>
<span class="line"></span>
<span class="line"><span class="token variable">$environment</span> <span class="token operator">=</span> <span class="token class-name static-context">App</span><span class="token operator">::</span><span class="token function">environment</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div></div></div><p>你还可以将参数传递给<code v-pre>environment</code>函数，以确定当前环境是否匹配给定的值。当环境匹配给参数它将返回<code v-pre>true</code></p>
<div class="language-php line-numbers-mode" data-highlighter="prismjs" data-ext="php" data-title="php"><pre v-pre class="language-php"><code><span class="line"><span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token class-name static-context">App</span><span class="token operator">::</span><span class="token function">environment</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'local'</span><span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></span>
<span class="line">    <span class="token comment">// 当前环境是 local</span></span>
<span class="line"><span class="token punctuation">}</span></span>
<span class="line"></span>
<span class="line"><span class="token keyword">if</span> <span class="token punctuation">(</span><span class="token class-name static-context">App</span><span class="token operator">::</span><span class="token function">environment</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token string single-quoted-string">'local'</span><span class="token punctuation">,</span> <span class="token string single-quoted-string">'staging'</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">)</span> <span class="token punctuation">{</span></span>
<span class="line">    <span class="token comment">// 当前环境是 local 或 staging ...</span></span>
<span class="line"><span class="token punctuation">}</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div></div></div><blockquote>
<p><strong>技巧</strong><br>
当前应用程序的环境检测，可以通过定义服务器级<code v-pre>APP_ENV</code>环境变量来覆盖。</p>
</blockquote>
<h3 id="环境文件加密" tabindex="-1"><a class="header-anchor" href="#环境文件加密"><span>环境文件加密</span></a></h3>
<p>未加密的环境文件不应该被存储在源码控制中. 然而, Laravel允许你加密你的环境文件, 这样他们就可以安全地与你的应用程序的其他部分一起被添加到源码控制中.</p>
<h4 id="加密" tabindex="-1"><a class="header-anchor" href="#加密"><span>加密</span></a></h4>
<p>为了加密环境文件，你可以使用<code v-pre>env:encrypt</code>命令。</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:encrypt</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>运行<code v-pre>env:encrypt</code>命令将加密你的<code v-pre>.env</code>文件，并将加密的内容放在<code v-pre>.env.encrypted</code>文件中。解密密钥将出现在命令的输出中，并应存储在一个安全的密码管理器中。如果你想提供你自己的加密密钥，你可以在调用该命令时使用<code v-pre>--key</code>选项:</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:encrypt <span class="token parameter variable">--key</span><span class="token operator">=</span>3UVsEgGVK36XN82KKeyLFMhvosbZN1aF</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><blockquote>
<p><strong>注意</strong><br>
所提供的密钥的长度应该与所使用的加密密码所要求的密钥长度相匹配. 默认情况下, Laravel会使用<code v-pre>AES-256-CBC</code>密码, 需要一个32个字符的密钥. 你可以自由地使用Laravel的 <a href="https://learnku.com/docs/laravel/10.x/encryption" target="_blank" rel="noopener noreferrer">encrypter</a> 所支持的任何密码，只要在调用该命令时传递<code v-pre>--cipher</code>选项即可。</p>
</blockquote>
<p>如果你的应用程序有多个环境文件，如<code v-pre>.env</code>和<code v-pre>.env.staging</code>，你可以通过<code v-pre>--env</code>选项提供环境名称来指定应该被加密的环境文件:</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:encrypt <span class="token parameter variable">--env</span><span class="token operator">=</span>staging</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h4 id="解密" tabindex="-1"><a class="header-anchor" href="#解密"><span>解密</span></a></h4>
<p>要解密一个环境文件, 你可以使用<code v-pre>env:decrypt</code>命令. 这个命令需要一个解密密钥, Laravel会从<code v-pre>LARAVEL_ENV_ENCRYPTION_KEY</code>环境变量中获取.:</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:decrypt</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>或者，密钥也可以通过 –key 选项直接提供给命令：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:decrypt <span class="token parameter variable">--key</span><span class="token operator">=</span>3UVsEgGVK36XN82KKeyLFMhvosbZN1aF</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>当执行 <code v-pre>env:decrypt</code> 命令时，Laravel 将解密 <code v-pre>.env.encrypted</code> 文件的内容，并将解密后的内容放置在 <code v-pre>.env</code> 文件中。</p>
<p>可以通过 <code v-pre>--cipher</code> 选项提供自定义加密算法的名称给 <code v-pre>env:decrypt</code> 命令：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:decrypt <span class="token parameter variable">--key</span><span class="token operator">=</span>qUWuNRdfuImXcKxZ <span class="token parameter variable">--cipher</span><span class="token operator">=</span>AES-128-CBC</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>如果你的应用程序有多个环境文件，例如 <code v-pre>.env</code> 和 <code v-pre>.env.staging</code>，可以通过 <code v-pre>--env</code> 选项提供环境名称来指定应该解密的环境文件：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:decrypt <span class="token parameter variable">--env</span><span class="token operator">=</span>staging</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>为了覆盖现有的环境文件，可以在 <code v-pre>env:decrypt</code> 命令中提供 <code v-pre>--force</code> 选项：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan env:decrypt <span class="token parameter variable">--force</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h2 id="访问配置值" tabindex="-1"><a class="header-anchor" href="#访问配置值"><span>访问配置值</span></a></h2>
<p>你可以在应用程序的任何地方使用全局 <code v-pre>config</code> 函数轻松访问你的配置值。可以使用 “点” 语法来访问配置值，其中包括你希望访问的文件和选项的名称。如果配置选项不存在，则可以指定默认值，如果不存在则返回默认值：</p>
<div class="language-php line-numbers-mode" data-highlighter="prismjs" data-ext="php" data-title="php"><pre v-pre class="language-php"><code><span class="line"><span class="token variable">$value</span> <span class="token operator">=</span> <span class="token function">config</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'app.timezone'</span><span class="token punctuation">)</span><span class="token punctuation">;</span></span>
<span class="line"></span>
<span class="line"><span class="token comment">// 如果配置值不存在，则检索默认值...</span></span>
<span class="line"><span class="token variable">$value</span> <span class="token operator">=</span> <span class="token function">config</span><span class="token punctuation">(</span><span class="token string single-quoted-string">'app.timezone'</span><span class="token punctuation">,</span> <span class="token string single-quoted-string">'Asia/Seoul'</span><span class="token punctuation">)</span><span class="token punctuation">;</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div></div></div><p>要在运行时设置配置值，请将数组传递给 <code v-pre>config</code> 函数：</p>
<div class="language-php line-numbers-mode" data-highlighter="prismjs" data-ext="php" data-title="php"><pre v-pre class="language-php"><code><span class="line"><span class="token function">config</span><span class="token punctuation">(</span><span class="token punctuation">[</span><span class="token string single-quoted-string">'app.timezone'</span> <span class="token operator">=></span> <span class="token string single-quoted-string">'America/Chicago'</span><span class="token punctuation">]</span><span class="token punctuation">)</span><span class="token punctuation">;</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h2 id="配置缓存" tabindex="-1"><a class="header-anchor" href="#配置缓存"><span>配置缓存</span></a></h2>
<p>为了提高应用程序的速度，你应该使用<code v-pre>config:cache</code>Artisan 命令将所有配置文件缓存到一个文件中。 这会将应用程序的所有配置选项组合到一个文件中，框架可以快速加载该文件。</p>
<p>你通常应该在生产部署过程中运行<code v-pre>php artisan config:cache</code> 命令。 该命令不应在本地开发期间运行，因为在应用程序开发过程中经常需要更改配置选项。</p>
<p>一旦配置被缓存，应用程序的。<code v-pre>.env</code>文件将不会在请求或 Artisan 命令期间被框架加载；因此， <code v-pre>env</code>函数将只返回外部的系统级环境变量。</p>
<p>因此，应确保仅从应用程序的配置<code v-pre>config</code>文件中调用<code v-pre>env</code>函数。通过检查 Laravel 的默认配置文件，你可以看到许多示例。可以使用<code v-pre>config</code>函数从应用程序中的任何位置访问配置值 <a href="#accessing-configuration-values">如上所述</a>。</p>
<blockquote>
<p><strong>注意</strong><br>
如果你在部署过程中执行<code v-pre>config:cache</code>命令，则应确保仅从配置文件中调用<code v-pre>env</code>函数。一旦配置被缓存，<code v-pre>.env</code>文件将不会被加载；因此，<code v-pre>env</code>函数只会返回外部的系统级环境变量。</p>
</blockquote>
<h2 id="调试模式" tabindex="-1"><a class="header-anchor" href="#调试模式"><span>调试模式</span></a></h2>
<p><code v-pre>config/app.php</code>配置文件中的<code v-pre>debug</code>选项决定了实际向用户显示的错误信息量。 默认情况下，此选项设置为尊重<code v-pre>APP_DEBUG</code>环境变量的值，该变量存储在你的<code v-pre>.env</code>文件中。</p>
<p>对于本地开发，你应该将<code v-pre>APP_DEBUG</code>环境变量设置为<code v-pre>true</code>。 <strong>在你的生产环境中，此值应始终为<code v-pre>false</code>。 如果在生产环境中将该变量设置为<code v-pre>true</code>，你可能会将敏感的配置值暴露给应用程序的最终用户。</strong></p>
<h2 id="维护模式" tabindex="-1"><a class="header-anchor" href="#维护模式"><span>维护模式</span></a></h2>
<p>当你的应用程序处于维护模式时，将为你的应用程序的所有请求显示一个自定义视图。 这使得在更新或执行维护时可以轻松「禁用」你的应用程序。 维护模式检查包含在应用程序的默认中间件堆栈中。 如果应用程序处于维护模式，则会抛出一个<code v-pre>Symfony\Component\HttpKernel\Exception\HttpException</code>实例，状态码为 503。</p>
<p>要启用维护模式，请执行<code v-pre>down</code>Artisan 命令：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>如果你希望<code v-pre>Refresh</code> HTTP 标头与所有维护模式响应一起发送，你可以在调用<code v-pre>down</code>命令时提供<code v-pre>refresh</code>选项。<code v-pre>Refresh</code> 标头将指示浏览器在指定秒数后自动刷新页面：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down <span class="token parameter variable">--refresh</span><span class="token operator">=</span><span class="token number">15</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>你还可以为<code v-pre>down</code>命令提供<code v-pre>retry</code> 选项，该选项将设置为<code v-pre>Retry-After</code> HTTP 标头的值，尽管浏览器通常会忽略此标头：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down <span class="token parameter variable">--retry</span><span class="token operator">=</span><span class="token number">60</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h4 id="绕过维护模式" tabindex="-1"><a class="header-anchor" href="#绕过维护模式"><span>绕过维护模式</span></a></h4>
<p>即使在维护模式下，你也可以使用<code v-pre>secret</code>选项来指定维护模式绕过令牌：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down <span class="token parameter variable">--secret</span><span class="token operator">=</span><span class="token string">"1630542a-246b-4b66-afa1-dd72a4c43515"</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>将应用程序置于维护模式后，你可以访问与该令牌匹配的应用程序 URL，Laravel 将为你的浏览器颁发一个维护模式绕过 cookie：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">https://example.com/1630542a-246b-4b66-afa1-dd72a4c43515</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><p>当访问此隐藏路由时，你将被重定向到应用程序的<code v-pre>/</code>路径。一旦 cookie 被颁发到你的浏览器，你就可以像维护模式不存在一样正常浏览应用程序。</p>
<blockquote>
<p><strong>技巧</strong><br>
你的维护模式 secret 通常应由字母数字字符和可选的破折号组成。应避免使用 URL 中具有特殊含义的字符，例如 <code v-pre>?</code>。</p>
</blockquote>
<h4 id="预渲染维护模式视图" tabindex="-1"><a class="header-anchor" href="#预渲染维护模式视图"><span>预渲染维护模式视图</span></a></h4>
<p>如果在部署期间中使用 <code v-pre>php artisan down</code> 命令，当你的 Composer 依赖或其基础组件更新的时候，你的用户也可能遇到偶然性的错误。这是因为 Laravel 框架的重要部分必须启动才能确定应用程序处于维护模式，并使用模板引擎呈现维护模式视图。</p>
<p>因此，Laravel 允许你预渲染一个维护模式视图，该视图将在请求周期的最开始返回。此视图在加载应用程序的任何依赖项之前呈现。可以使用 <code v-pre>down</code> 命令的 <code v-pre>render</code> 选项预渲染所选模板：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down <span class="token parameter variable">--render</span><span class="token operator">=</span><span class="token string">"errors::503"</span></span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h4 id="重定向维护模式请求" tabindex="-1"><a class="header-anchor" href="#重定向维护模式请求"><span>重定向维护模式请求</span></a></h4>
<p>在维护模式下，Laravel 将显示用户试图访问的所有应用程序 url 的维护模式视图。如果你愿意，你可以指示 Laravel 重定向所有请求到一个特定的 URL。这可以使用 <code v-pre>redirect</code> 选项来实现。例如，你可能希望将所有请求重定向到 <code v-pre>/</code> URI：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan down <span class="token parameter variable">--redirect</span><span class="token operator">=</span>/</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><h4 id="禁用维护模式" tabindex="-1"><a class="header-anchor" href="#禁用维护模式"><span>禁用维护模式</span></a></h4>
<p>要禁用维护模式，请使用 <code v-pre>up</code> 命令：</p>
<div class="language-bash line-numbers-mode" data-highlighter="prismjs" data-ext="sh" data-title="sh"><pre v-pre class="language-bash"><code><span class="line">php artisan up</span>
<span class="line"></span></code></pre>
<div class="line-numbers" aria-hidden="true" style="counter-reset:line-number 0"><div class="line-number"></div></div></div><blockquote>
<p><strong>技巧</strong><br>
你可以通过在<code v-pre>resources/views/errors/503.blade.php</code>中定义自己的维护模式模板。</p>
</blockquote>
<h4 id="维护模式-队列" tabindex="-1"><a class="header-anchor" href="#维护模式-队列"><span>维护模式 &amp; 队列</span></a></h4>
<p>当应用程序处于维护模式时，将不会处理任何 <a href="https://learnku.com/docs/laravel/10.x/queues" target="_blank" rel="noopener noreferrer">队列任务</a>。一旦应用程序退出维护模式，像往常一样继续处理。</p>
<h4 id="维护模式的替代方法" tabindex="-1"><a class="header-anchor" href="#维护模式的替代方法"><span>维护模式的替代方法</span></a></h4>
<p>由于维护模式要求你的应用程序有几秒钟的停机时间，因此你可以考虑使用 <a href="https://vapor.laravel.com/" target="_blank" rel="noopener noreferrer">Laravel Vapor</a> 和 <a href="https://envoyer.io/" target="_blank" rel="noopener noreferrer">Envoyer</a> 等替代方案来实现 Laravel 零停机部署。</p>
<blockquote>
<p>本译文仅用于学习和交流目的，转载请务必注明文章译者、出处、和本文链接<br>
我们的翻译工作遵照 <a href="https://learnku.com/docs/guide/cc4.0/6589" target="_blank" rel="noopener noreferrer">CC 协议</a>，如果我们的工作有侵犯到您的权益，请及时联系我们。</p>
</blockquote>
<hr>
<blockquote>
<p>原文地址：<a href="https://learnku.com/docs/laravel/10.x/configuration/14836" target="_blank" rel="noopener noreferrer">https://learnku.com/docs/laravel/10.x/co...</a></p>
<p>译文地址：<a href="https://learnku.com/docs/laravel/10.x/configuration/14836" target="_blank" rel="noopener noreferrer">https://learnku.com/docs/laravel/10.x/co...</a></p>
</blockquote>
</div></template>


